

#### IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

Applicant:

Heer

Docket No.:

2002 P 10624 US

Serial No.:

10/724,011

Art Unit:

2121

Filed:

November 26, 2003

Examiner:

**TBD** 

For:

Arrangement of Configurable Logic Blocks

Commissioner for Patents P.O. Box 1450 Alexandria, VA 22313-1450

### **Transmittal of Certified Copy of Priority Document**

Dear Sir:

Attached please find a certified copy of the foreign application from which priority is claimed for this case:

Country:

Germany

Application Number: 102 55 768.3

Filing Date:

November 28, 2002

Respectfully submitted,

Ira S. Matsil

Reg. No. 35,272

Attorney for Applicant

Slater & Matsil, L.L.P. 17950 Preston Rd., Suite 1000

Dallas, TX 75252 Tel: 972-732-1001 Fax: 972-732-9218

# BUNDESREPUBLIK DEUTSCHLAND



# Prioritätsbescheinigung über die Einreichung einer Patentanmeldung

Aktenzeichen:

102 55 768.3

**Anmeldetag:** 

28. November 2002

Anmelder/Inhaber:

Infineon Technologies AG,

München/DE

Bezeichnung:

Anordnung von konfigurierbaren Logik

Blöcken

IPC:

H 03 K 19/177

Die angehefteten Stücke sind eine richtige und genaue Wiedergabe der ursprünglichen Unterlagen dieser Patentanmeldung.

München, den 27. November 2003

Deutsches Patent- und Markenamt

Der Präsident Im Auftrag

≥i<sub>&c</sub>

10

25

1



### Anordnung von konfigurierbaren Logik Blöcken

Die Erfindung betrifft eine Anordnung von konfigurierbaren Logik Blöcken (CLB) in kundenspezifischen Schaltkreisen, welche in der Field Programmable Gate Arrays (FPGA) Technologie gefertigt werden, wobei die CLB aus einem oder mehreren Lookup-Tabellen (LUT), aus einem ersten und/oder zweiten Multiplexer und einer CLB-Steuerlogik bestehen.

- 15 Seit ihrer Einführung 1980 sind Field Programmable Logic
  Devices (FPLD), also die feld-programmierbaren logischen
  Bauelemente, ein integraler Bestandteil für die digitalen
  Schaltkreisimplementationen.
  - Diese moderne Realisierungs-Variante für digitale Schaltung bietet großer Vorteile gegenüber dem konventionellen VLSI Designs auf den Gebieten Fertigungskosten, zeitnahe Produktbereitstellung auf dem Markt (schnelle Marktreife) und günstige Systemmodifikation.
    - Diese FPLD weisen neben programmierbarer Logik auch komplexe programmierbare Verdrahtung auf. Dadurch ist die Realisierung mehrstufiger Logik möglich.
- Die programmierbare Verdrahtung wird üblicherweise in einer jeweiligen Switch-Matrix ausgeführt, was aber die Komplexität der Verschaltung begrenzt.
  - So haben sich in den letzten Jahren die Anwendungen der Feld 35 Programmierbaren Gate Arrays (FPGA) als ein den FPLD zugehöriger Technologiebereich besonders stark entwickelt.

## Anordnung von konfigurierbaren Logik Blöcken

Die Erfindung betrifft eine Anordnung von konfigurierbaren Logik Blöcken (CLB) in kundenspezifischen Schaltkreisen, welche in der Field Programmable Gate Arrays (FPGA) Technologie gefertigt werden, wobei die CLB aus einem oder mehreren Lookup-Tabellen (LUT), aus einem ersten und/oder zweiten Multiplexer und einer CLB-Steuerlogik bestehen.



5

10

Seit ihrer Einführung 1980 sind Field Programmable Logic Devices (FPLD), also die feld-programmierbaren logischen Bauelemente, ein integraler Bestandteil für die digitalen Schaltkreisimplementationen.

- Diese moderne Realisierungs-Variante für digitale Schaltung bietet großer Vorteile gegenüber dem konventionellen VLSI 20 Fertigungskosten, Gebieten den Designs Produktbereitstellung auf dem Markt (schnelle Marktreife) und günstige Systemmodifikation.
- Diese FPLD weisen neben programmierbarer Logic auch komplexe programmierbare Verdrahtung auf. Dadurch ist die Realisierung mehrstufiger Logik möglich.



35

Die programmierbare Verdrahtung wird üblicherweise in einer jeweiligen Switch-Matrix ausgeführt, was aber die Komplexität der Verschaltung begrenzt.

So haben sich in den letzten Jahren die Anwendungen der Feld Programmierbaren Gate Arrays (FPGA) als ein den FPLD zugehöriger Technologiebereich besonders stark entwickelt. Da in diesen FPGA beliebig verteilte kombinatorische Logik-Schaltungen mit sequenziellen Schaltungsteilen komplex

20

35

Da in diesen FPGA beliebig verteilte kombinatorische Logikkomplex sequenziellen Schaltungsteilen mit Schaltungen verknüpft sein können, werden hierbei universelle, skalierbare Schaltungen realisiert.

in diesem Technologiebereich besonders Deshalb ist vorteilhaft, anwenderprogrammierbare Schaltkreise zu entwerfen und zu fertigen.

Dies zeigt sich besonders deutlich in der Tendenz, dass beim Stand der Technik gerade Micro-Controller und Ablaufsteuerungen 10 etc. häufig als FPGA entwickelt werden.

Dabei hat es sich herauskristallisiert, dass eine überschaubare Anzahl von großen Herstellern (z.B. ACTEL, XILINX) ihre zur Programmierung durch den Anwender angebotenen FPGA als De-Facto-Standards auf dem Markt eingeführt haben.

diesen angebotenen Schaltkreistypen kann man solche Grundstrukturen feststellen, bei denen die FPGA aus einem Array komplexen Logik Blöcken besteht. Hierbei sind die aber auch Konfigurationen der Logikblöcken selbst, Verbindungen zwischen den Logikblöcken programmierbar.

So besteht beim Stand der Technik ein weitverbreiteter konfigurierbarer Logik Block (CLB) in seinem kombinatorischem 25 Schaltungsteil aus Lookup-Tabellen (LUT), die vorzugsweise durch statische RAM realisiert werden. In diesen Lookup-Tabellen werden beliebige kombinatorische Funktionen umgesetzt, die durch Wahrheits-Tabellen repräsentiert werden.

von auch Wahrheitstabellen spricht man diesen Bei ihrer Realisierung Funktionstabellen, die neben Matrixspeicher z.B. auch durch Multiplexer ergänzt oder durch sie alleinig realisiert werden.

Die sequenziellen Funktionen des konfigurierbaren Logik Blocks CLB-Steuerlogik sequentielle eine durch werden (CLB) ausgeführt, deren Speicherelemente D-FF darstellen.

Da die einzelnen CLB im FPGA meist gitterförmig angeordnet sind, erfolgt auch eine gitterförmige Verdrahtung dieser CLB.

Die o.g. programmierbare Verdrahtung der CLB wird durch Schalter an den Schnittstellen z.B. mit den sogenannten Passtransistoren ausgeführt.

Die FPLD im Allgemeinen und die FPGA im Besonderen werden bevorzugt für Anwendungen in der Kommunikationstechnik, in der Prozessrechentechnik, für industrielle Gerätesteuerungen etc. verwendet, da diese Anwendungsbereiche sehr berechnungsintensiv sind.

Einerseits erlangen FPGA auch deswegen eine so weit verbreitete Bedeutung für die Implementierung von Signalprozessen und 15 Algorithmen, weil hierbei diese sehr effektiv als Parallel-Prozesse ausgeführt werden können.

Anderseits erfordert die Umsetzung von solchen parallelen Berechnungen in der durch FFGA realisierten Hardware, dass auch 20 komplexe Berechnungs- bzw. Steuerungsvorgänge, wie sie z.B. bedingte Verzweigungen darstellen, eine ebenso komplexe Realisierung in ihren CLB erfährt.

Bei dieser Realisierung der CLB ist ersichtlich, dass bei 25 bestimmten angewendeten Zellarchitekturen, die durch häufige Standardzell-Gattern (fine-grain) von Anwendungen gekennzeichnet ist, viele Verdrahtungselemente notwendig sind und/oder bei häufiger Verwendung komplexerer Logik (coarsgrain) auch Logik häufig ungenutzt bleibt.

Durch diesen schwer auszubalancierenden Anteil an nicht und/oder zusätzlichen Logikelementen ausnutzbaren Verdrahtungselementen ergibt sich bei der Realisierung der Komplexität von Anwender-Schaltungen in dieser FPGA-Technologie 35 eine effizienzmindernde gegenläufige Tendenz, die ein etwas höherem Flächenaufwand auf dem Schaltkreis, z.B. gegenüber vergleichbaren VLSI/CPLD-Realisierungen, bedingt.

Daraus ergibt sich die erfindungsgemäße Aufgabenstellung, den Flächenaufwand für konfigurierbare Logikblöcke (CLB) zu minimieren, in dem ihre jeweiligen Bestandteile an die funktionalen Aufgabe des CLB angepasst werden.

So sieht die erfindungsgemäße Lösung der Aufgabenstellung vor, dass ein CLB eine erste und/oder zweite Lookup-Tabelle enthält, in die mit ihrer inhaltsbezogenen Adressierbarkeit jeweils die Schaltfunktion mindestens einer bedingten Verzweigung implementiert ist, bei der eine "If then else"-Verzweigung generiert wird, die einen Vergleich von CLB-Eingangsdaten mit einem vorher in den CLB gespeichertes Vergleichsdatum realisiert.

15

20

10

Hierbei ist der Dateneingang des CLB über einen EingangsDatenbus einerseits mit einem jeweiligen Bus-Eingang einer
ersten und/oder zweiten Lookup-Tabelle und anderseits zumindest
in einem Teil der Bitbreite des Eingangs-Datenbus mit einem
jeweiligen Multiplexer-Steuereingang des ersten und/oder
zweiten Multiplexers und außerdem mit dem ersten Eingang der
CLB-Steuerlogik verbunden.

Weiterhin ist ein Steuereingang des CLB über einen Steuer-Bus 25 an einen zweiten Eingang der CLB-Steuerlogik angeschlossen.

Außerdem ist ein jeweiliger Ergebnis-Ausgang der ersten und/oder zweiten Lookup-Tabelle dem dritten bzw. vierten Eingang der CLB-Steuerlogik zugeordnet und es ist ein jeweiliger Registerdaten-Bus-Ausgang der ersten und/oder zweiten Lookup-Tabelle über einen ersten und/oder Register-Datenbus mit einem jeweiligen Bus-Eingang des ersten bzw. zweiten Multiplexers verbunden.

35 Ein Ausgang des ersten und/oder zweiten Multiplexers ist mit einem fünften bzw. sechsten Eingang der CLB-Steuerlogik verbunden und ein Ausgang der CLB-Steuerlogik bildet einen Ausgang des CLB.

10

30

5

So zielt diese erfindungsgemäße Lösung darauf ab, durch die Implementierung von einer bedingten Verzweigung mit ihren entsprechenden Schaltfunktion in einer spezielle LUT den Aufwand von sonst drei weiteren herkömmlichen LUT in einem CLB zu vermeiden.

Auf diese Weise wird ein erheblicher Teil des Flächenbedarfes des FPGAs bei der Realisierung der anwenderspezifischen Schaltung eingespart.

Eine besondere Ausführung der erfindungsgemäßen Lösung der Aufgabenstellung sieht vor, dass die erste und/oder zweite Lookup-Tabelle (LUT) mit der in ihr implementierten bedingten Verzweigung durch eine solche Schaltfunktionen realisiert wird, bei der diese erste und/oder zweite Lookup-Tabelle jeweils ein 15

erstes bzw. zweites Register enthält, in welchem das jeweilige Vergleichsdatum abgelegt wird.

Weiterhin weist die LUT jeweils einen die Eingangsdaten mit den abgelegten Vergleichsdaten vergleichenden ersten bzw. zweiten 20 Komparator auf, wobei der jeweilige Bus-Eingang der ersten und/oder zweiten Lookup-Tabelle mit einem jeweiligen ersten Bus-Eingang des ersten bzw. zweiten Komparators verbunden ist.

jeweiliger Bus-Ausgang des ersten und/oder zweiten 25 Registers ist mit einem jeweiligen zweiten Bus-Eingang des ersten bzw. zweiten Komparators und außerdem mit dem jeweiligen Registerdaten-Bus-Ausgang der ersten und/oder zweiten Lookup-Tabelle verbunden.

Außerdem ist ein jeweiliger Ausgang des ersten/und oder zweiten Komparators mit dem jeweiligen Ergebnis-Ausgang der ersten und/oder zweiten Lookup-Tabelle geschaltet.

Bei dieser besonderen Ausführung der erfindungsgemäßen Lösung 35 bei Geltung, dass vorteilhaft zur kommt sehr Implementierung von mehr als einer bedingten Verzweigungen in



einer LUT eine zusätzliche Einsparung von Hardware-Ressourcen durch Verringerung der benötigten CLB erreicht wird.

Darüber hinaus wird hierbei günstig sichergestellt, dass die im LUT abgelegten Vergleichsdaten auch zur Weiterverarbeitung in den üblichen Multiplexern eines CLB, die für die aufbereitende Zusammenarbeit mit der CLB-Steuerung erforderlich sind, gleichzeitig schon bereitgestellt sind.

Dadurch wird sonst erforderliche zusätzliche Hardware je 10 verwendeten CLB ebenfalls einspart.

Die Erfindung soll nachfolgend anhand eines Ausführungsbeispieles näher erläutert werden.

15 In der zugehörigen Zeichnungsfigur ist die Anordnung des CLB 9 mit den erfindungsgemäß implementierten ersten und zweiten Lookup-Tabellen (LUT) 2; 12 dargestellt.

So ist in dieser Zeichnungsfigur der CLB 9 mit den enthaltenen ersten und zweiten LUT 2; 12 sowie der ersten und zweiten Multiplexer 3; 13 und der CLB-Steuerlogik 8 ersichtlich, wobei in der ersten und zweiten LUT 2; 12 jeweils die darin enthaltenen ersten beziehungsweise zweiten Register 4; 14 sowie ebenfalls darin enthaltene ersten beziehungsweise zweite Z5 Komparator 6; 16 aufgeführt sind.

Vom Dateneingangs 1 des CLB 9 gelangen die anstehenden Daten über den Eingangs-Datenbus 7 an den jeweiligen Bus-Eingang des ersten beziehungsweise zweiten LUT 2; 12 und damit an den jeweiligen ersten Bus-Eingang des ersten beziehungsweise zweiten Komparators 6; 16.

Gleichzeitig gelangen diese Daten zumindest in einem Teil der Bit-Breite des Einganges-Datenbus 7 an den jeweiligen Multiplexer-Steuereingang des ersten und/oder zweiten Multiplexers 3; 13 und außerdem an den ersten Eingang der CLB-Steuerlogik 8.

Vom Steuereingang 10 des CLB 9 gelangen die Steuerdaten über den Steuer-Datenbus 7 an den zweiten Eingang der CLB-Steuerlogik 8.

- Die jeweiligen Vergleichdaten, die im ersten beziehungsweise zweiten Register 4; 14 gespeichert wurden, werden an dem jeweiligen zweiten Bus-Eingang des ersten beziehungsweise zweiten Komparators 6; 16 bereitgestellt.
- 10 Ebenfalls gelangen diese Daten an den Registerdaten-Bus-Ausgang der ersten und/oder zweiten Lookup-Tabelle 2; 12 und werden über einen jeweiligen ersten beziehungsweise zweiten Register-Datenbus 5; 15 an den Bus-Eingang des ersten beziehungsweise zweiten Multiplexers 3; 13 geschalten.

Das Ergebnis des jeweiligen Vergleiches der anstehenden Eingangsdaten mit den gespeicherten Vergleichsdaten wird am Ausgang des ersten beziehungsweise zweiten Komparators 6; 16 ausgegeben und gelangt über den jeweiligen Ergebnis-Ausgang der ersten und/oder zweiten Lookup-Tabelle 2; 12 an den dritten bzw. vierten Eingang der CLB-Steuerlogik 8.

Das am jeweiligen Ausgang des ersten beziehungsweise zweiten Multiplexers 3; 13 bereitgestellte Signal wird am fünften beziehungsweise sechsten Eingang der CLB-Steuerlogik 8 zur Verfügung gestellt. Deren Ausgangssignal wird an den Datenausgang 11 des CLB 9 geschalten.



30

15

20

35

8

# Anordnung von konfigurierbaren Logik Blöcken

#### Bezugzeichenliste

|    | 1  | Dateneingang                                          |
|----|----|-------------------------------------------------------|
| 10 | 2  | erste Lookup-Tabelle (LUT)                            |
|    | 3  | erster Multiplexer                                    |
|    | 4  | erstes Register                                       |
|    | 5  | erster Register-Datenbus                              |
|    | 6  | erster Komparator                                     |
| 15 | 7  | Eingangs-Datenbus                                     |
|    | 8  | CLB-Steuerlogik                                       |
|    | 9  | CLB, konfigurierbarer Logik-Block (Configurable Logic |
|    |    | Block)                                                |
|    | 10 | Steuereingang                                         |
| 20 | 11 | Datenausgang                                          |
|    | 12 | zweite Lookup-Tabelle (LUT)                           |
|    | 13 | zweiter Multiplexer                                   |
|    | 14 | zweites Register                                      |
|    | 15 | zweiter Register-Datenbus                             |
| 25 | 16 | zweiter Komparator                                    |
|    | 17 | Stouer-Datenbus                                       |

10

15

20

25

30

35

### Anordnung von konfigurierbaren Logik Blöcken

#### Patentansprüche

Anordnung von konfigurierbaren Logik Blöcken (CLB) in kundenspezifischen Schaltkreisen, welche in der Field Programmable Gate Arrays (FPGA) Technologie gefertigt werden, wobei die CLB aus einem oder mehreren Lookup-Tabellen (LUT), einem ersten und/oder zweiten Multiplexer dadurch bestehen, CLB-Steuerlogik einer gekennzeichnet, dass ein CLB (9) eine erste und/oder zweite Lookup-Tabelle (2),(12) enthält, in die mit ihrer Adressierbarkeit jeweils inhaltsbezogenen Schaltfunktion mindestens einer bedingten Verzweigung implementiert ist, bei der eine solche "If then else"-Verzweigung generiert wird, die einen Vergleich von Eingangsdaten des CLB (9) mit einem vorher in die LUT jeweils gespeicherten Vergleichsdatums realisiert, wobei der Dateneingang (1) des CLB (9) über einen Eingangs-Datenbus (7) einerseits mit einem jeweiligen Bus-Eingang einer ersten und/oder zweiten Lookup-Tabelle (2),(12) und anderseits zumindest ii einem Teil der Bitbreite des Eingangs-Datenbus (7) mit einem jeweiligen Multiplexer-Steuereingang des ersten und/oder zweiten Multiplexers (3),(13) und außerdem mit einem ersten Eingang der CLB-Steuerlogik (8) verbunden ist,

dass ein Steuereingang (10) des CLB (9) über einen Steuer-Bus (17) an einen zweiten Eingang der CLB-Steuerlogik (8) angeschlossen ist,

dass ein jeweiliger Ergebnis-Ausgang der ersten und/oder zweiten Lookup-Tabelle (2),(12) dem dritten bzw. vierten Eingang der CLB-Steuerlogik (8) zugeordnet ist,

10

15

20

25

30

2.

dass ein jeweiliger Registerdaten-Bus-Ausgang der ersten und/oder zweiten Lookup-Tabelle (2),(12) über einen ersten und/oder zweiten Register-Datenbus (5), (15) mit einem jeweiligen Bus-Eingang des ersten bzw. zweiten Multiplexers (3),(13) verbunden ist,

dass ein Ausgang des ersten und/oder zweiten Multiplexers (3),(13) mit einem fünften bzw. sechsten Eingang der CLB-Steuerlogik (8) verbunden ist,

dass ein Ausgang der CLB-Steuerlogik (8) einen Ausgang des CLB (9) bildet.

dadurch Anspruch 1, Anordnung nach gekennzeichnet, dass die erste und/oder zweite Lookup-Tabelle (2), (12) mit der in ihr implementierten bedingten Verzweigung durch eine solche Schaltfunktionen realisiert wird, bei der diese erste und/oder zweite Lookup-Tabelle (2), (12) jeweils ein erstes bzw. zweites Register (4), (14) enthält, in welchem das jeweilige Vergleichsdatum abgelegt ist, und weiterhin jeweils einen die Eingangsdaten mit den abgelegten Vergleichsdaten vergleichenden ersten bzw. zweiten Komparator (6), (16) aufweist, wobei der jeweilige Bus-Eingang der ersten und/oder zweiten Lookup-Tabelle (2), (12) mit einem jeweiligen ersten Bus-Eingang des ersten bzw. zweiten Komparators (6), (16) verbunden ist und ein jeweiliger Bus-Ausgang des ersten und/oder zweiten Registers (4), (14) mit einem jeweiligen zweiten Bus-Eingang des ersten bzw. zweiten Komparators (6), (16) und außerdem mit dem jeweiligen Registerdaten-Bus-Ausgang der ersten und/oder zweiten Lookup-Tabelle (2), (12) verbunden ist, dass ein jeweiliger Ausgang des ersten/und oder zweiten Komparators (6),(16) mit dem jeweiligen Ergebnis-Ausgang der ersten und/oder zweiten Lookup-Tabelle (2),(12) geschaltet ist.



Nr.4528 S. 17/18

5

## Anordnung von konfigurierbaren Logik Blöcken

#### Zusammenfassung

Die Erfindung betrifft eine Anordnung von CLB, welche in der 10 FPGA Technologie gefertigt werden und löst die erfindungsgemäße Aufgabenstellung, durch Anpassung ihrer jeweiligen Bestandteile an die funktionalen Aufgabe des CLB den Aufwand zu minimieren, ein CLB eine erste und/oder zweite Lookup-Tabelle enthält, in die jeweils die Schaltfunktion mindestens einer 15 bedingten Verzweigung implementiert ist. Dateneingang des CLB über einen Eingangs-Datenbus einerseits mit einem jeweiligen Bus-Eingang einer ersten und/oder zweiten Lookup-Tabelle und anderseits zumindest in Teilen der Bitbreite Eingangs-Datenbus mit einem jeweiligen Multiplexer-20 Steuereingang des ersten und/oder zweiten Multiplexers und außerdem mit dem ersten Eingang der CLB-Steuerlogik verbunden und es ist ein Steuereingang des CLB über einen Steuer-Bus an einen zweiten Eingang der CLB-Steuerlogik angeschlossen. Außerdem ist ein jeweiliger Ergebnis-Ausgang der ersten 25 und/oder zweiten Lookup-Tabelle dem dritten bzw. vierten Eingang der CLB-Steuerlogik zugeordnet und es ersten und/oder . jeweiliger Registerdaten-Bus-Ausgang der zweiten Lookup-Tabelle mit einem jeweiligen Bus-Eingang des ersten bzw. zweiten Multiplexers verbunden. Ein Ausgang des 30 ersten und/oder zweiten Multiplexers ist mit einem fünften bzw. sechsten Eingang der CLB-Steuerlogik verbunden und ein Ausgang der CLB-Steuerlogik bildet einen Ausgang des CLB. (Fig.)

